from . import news_blue
from flask import render_template,current_app,session,abort,g,jsonify,request
from info.models import News,Category,User,Comment,CommentLike
from info.utils.comment import user_login_data
from info import response_code,db,constants



@news_blue.route('/followed_user',methods = ['POST'])
@user_login_data
def followed_user():
    '''关注和取消关注'''
    #1.获取登陆用户信息
    login_user = g.user
    if not login_user:
         return jsonify(errno=response_code.RET.SESSIONERR, errmsg='用户未登录')
    #2.接受参数
    user_id = request.json.get('user_id')
    action = request.json.get('action')

    #3.校验参数
    if not all(['user_id','action']):
         return jsonify(errno=response_code.RET.PARAMERR, errmsg='缺少参数')
    if action not in ['follow','unfollow']:
         return jsonify(errno=response_code.RET.PARAMERR, errmsg='缺少参数')

    #4.查询要关注的人是否存在
    try:
        other = User.query.get(user_id)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=response_code.RET.DBERR, errmsg='查询用户失败')
    if not other:
        return jsonify(errno=response_code.RET.NODATA, errmsg='用户不存在')

    #5.实现关注和取消关注
    if action == 'follow':
    #关注
        if other not in login_user.followed:
            login_user.followed.append(other)
        else:
             return jsonify(errno=response_code.RET.DATAEXIST, errmsg='以关注')
    else:
    #取消关注
        if other in login_user.followed:
            login_user.followed.remove(other)
        else:
             return jsonify(errno=response_code.RET.DATAEXIST, errmsg='未关注')
    #6.同步到数据库
    try:
        db.session.commit()
    except Exception as e:
        db.session.rollback()
        current_app.logger.error(e)
        return jsonify(errno=response_code.RET.DBERR, errmsg='保存到数据库失败')
    #7.响应结果
    return jsonify(errno=response_code.RET.OK, errmsg='OK')











@news_blue.route('/comment_like',methods=['post'])
@user_login_data
def comment_like():
    '''新闻点赞'''
    #1.获取用户的登录信息
    user = g.user
    if not user:
         return jsonify(errno=response_code.RET.SESSIONERR, errmsg='用户未登录')

    #2.接受参数
    comment_id = request.json.get('comment_id')
    action = request.json.get('action')
    #3.校验参数
    if not all(['comment_id','action']):
         return jsonify(errno=response_code.RET.PARAMERR, errmsg='缺少参数')
    if action not in ['add','remove']:
         return jsonify(errno=response_code.RET.PARAMERR, errmsg='缺少参数')

    #根据客户传入的comment_id查询出要点赞的评论
    try:
        comment = Comment.query.get(comment_id)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=response_code.RET.DBERR, errmsg='查询评论失败')
    if not comment:
         return jsonify(errno=response_code.RET.NODATA, errmsg='评论不存在')

    #4.查询要点赞的评论的赞是否存在,查询当前用户是否给当前评论点过赞
    try:
        comment_like_model = CommentLike.query.filter(CommentLike.comment_id == comment_id,CommentLike.user_id == user.id).first()
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=response_code.RET.DBERR, errmsg='查询点赞失败')



    #5.点赞和取消点赞
    if action == 'add':
        #点赞
        if not comment_like_model:
            comment_like_model = CommentLike()
            comment_like_model.user_id = user.id
            comment_like_model.comment_id = comment_id

            #将新的记录添加到数据库
            db.session.add(comment_like_model)
            #累加点赞量
            comment.like_count +=1

        else:
            #取消点赞
            if comment_like_model:
                db.session.delete(comment_like_model)
                # 减少点赞量
                comment.like_count -= 1
        #所有数据同步到数据库
        try:
            db.session.commit()
        except Exception as e:
            db.session.rollback()
            current_app.logger.error(e)

    #6.响应点赞和取消点赞的结果
    return jsonify(errno=response_code.RET.OK, errmsg='OK')

    #7.响应点赞和取消点赞的结果




@news_blue.route('/news_comment',methods=['post'])
@user_login_data
def add_news_comment():
    '''添加评论'''
    user = g.user
    if not user:
         return jsonify(errno=response_code.RET.SESSIONERR, errmsg='用户未登录')

    #获取参数(被评论新闻id，评论内容，被回复评论id)
    news_id = request.json.get('news_id')
    comment_content = request.json.get('comment')
    parent_id = request.json.get('parent_id')

    #3.校验请求参数
    if not all([news_id,comment_content]):
         return jsonify(errno=response_code.RET.PARAMERR, errmsg='缺少参数')
    try:
        news_id = int(news_id)
        if parent_id:
            parent_id = int(parent_id)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=response_code.RET.PARAMERR, errmsg='缺少参数')


    #4.校验新闻是否存在
    try:
        news = News.query.get(news_id)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=response_code.RET.DBERR, errmsg='查询新闻数据失败')
    if not news:
        return jsonify(errno=response_code.RET.DBERR, errmsg='新闻数据不存在不存在')

    #5.初始化评论模型对象，并赋值，同步到数据库
    comment = Comment()
    comment.user_id = user.id
    comment.news_id = news_id
    comment.content = comment_content
    if parent_id:
        comment.parent_id = parent_id
    try:
        db.session.add(comment)
        db.session.commit()
    except Exception as e:
        current_app.logger.error(e)
        db.session.rollback()
        return jsonify(errno=response_code.RET.DBERR, errmsg='存储评论数据失败')

    #6.响应评论结果结果
    return jsonify(errno=response_code.RET.OK, errmsg='操作成功',data = comment.to_dict())







#收藏和取消收藏
@news_blue.route('/news_collect',methods=['post'])
@user_login_data
def news_collect():
   '''新闻收藏'''
   #1.获取登录用户信息
   user = g.user
   if not user:
        return jsonify(errno=response_code.RET.SESSIONERR, errmsg='用户未登录')

   #2.接受参数（news_id，action）
   news_id = request.json.get('news_id')
   action = request.json.get('action')


   #3.校验参数
   if not all([news_id,action]):
        return jsonify(errno=response_code.RET.PARAMERR, errmsg='缺少参数')
   if action not in ['collect','cancel_collect']:
        return jsonify(errno=response_code.RET.PARAMERR, errmsg='参数错误')

   #4.查询代收藏的新闻信息
   try:
       news = News.query.get(news_id)
   except Exception as e:

       current_app.logger.error(e)
       return jsonify(errno=response_code.RET.DBERR, errmsg='查询新闻数据失败')
   if not news:
       return jsonify(errno=response_code.RET.NODATA, errmsg='新闻数据不存在')

   #5.收藏新闻
   if action == 'collect':
       #当要收藏的新闻不在用户的收藏列表中才需要收藏
       if news not in user.collection_news:
        user.collection_news.append(news)
   else:
       #当要取消收藏的新闻在用户的收藏列表中才需要收藏
       if news in user.collection_news:
            user.collection_news.remove(news)

   try:
       db.session.commit()
   except Exception as e:

       current_app.logger.error(e)
       db.session.rollback()
       return jsonify(errno=response_code.RET.DBERR, errmsg='操作失败')

    #6.响应操作结果

   return jsonify(errno=response_code.RET.OK, errmsg='操作成功')










@news_blue.route('/detail/<int:news_id>')
@user_login_data
#news_detail当作装饰器传入到@user_login_data装饰器里面
def news_detail(news_id):
    '''
    新闻详情
    :return: news_id:要查寻的新闻id
    1.查询用户的登录信息
    2.查询点击排行榜
    3.查询新闻详情
    4.累加点击量
    5.收藏和取消收藏
    6.展示用户的评论
    7.展示评论点的赞
    8.关注和取消关注
    '''


    user = g.user

    #查询点击排行榜
    news_clicks = []
    try:
        news_clicks = News.query.order_by(News.clicks.desc()).limit(constants.CLICK_RANK_MAX_NEWS)

    except Exception as e:
        current_app.logger.error(e)
    #3.查询新闻详情
    news = None
    try:
        news = News.query.get(news_id)
    except Exception as e:
        current_app.logger.error(e)
    #后续会给404的异常准备一个友好的页面
    if not news:
        abort(404)

    #4.累加点击量
    news.clicks +=1
    try:
        db.session.commit()
    except Exception as e:
        current_app.logger.error(e)
        db.session.rollback()

    #5.收藏和取消收藏
    is_collected = False

    if user:
        if news in user.collection_news:
            is_collected = True

    #6.展示用户的评论
    comments = []
    # if user:
    try:
        comments = Comment.query.filter(Comment.news_id==news_id).order_by(Comment.create_time.desc()).all()
    except Exception as e:
        current_app.logger.error(e)

    #7.展示评论的赞
    comment_like_ids = []
    if user:
        try:
            # 查询用户点赞了哪些评论
            comment_likes = CommentLike.query.filter(CommentLike.user_id==user.id).all()
            #取出所有被用户点赞的评论id
            comment_like_ids = [comment_like.comment_id for comment_like in comment_likes]
        except Exception as e:
            current_app.logger.error(e)

    #因为我希望界面渲染的数据，是经过处理的，所以我不使用模型类原始的数据，而把每个模型类转成字典to_dict()
    comment_dict_list = []
    for comment in comments:
        comment_dict = comment.to_dict()
        #给comment_dict追加一个is_like用于记录该评论是否被用户点赞了
        comment_dict['is_like'] = False
        if comment.id in comment_like_ids:
            comment_dict['is_like'] = True

        comment_dict_list.append(comment_dict)

    #8.关注和取消关注显示逻辑
    is_followed = False
    #当用户已登陆且登陆用户正在看的新闻有作者
    if user and news.user:
        if news.user in user.followed:
            is_followed = True

    context = {
        'user':user.to_dict() if user else None,
        'news_clicks':news_clicks,
        'news':news.to_dict(),
        'is_collected':is_collected,
        'comment':comment_dict_list,
        'is_followed':is_followed,

    }


    #渲染模板
    return render_template('news/detail.html',context = context)